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SECTION  I — ABSTRACT 

This  paper  presents  precise  versions  of  some  "laws"  that  must  be  satUfied  by  computations  involving 
communicating  parallel  processes.  The  laws  take  the  form  of  stating  plausible  restrictions  on  the 
histories  of  computations  that  are  physically  realizable.  The  laws  are  very  general  in  that  they  are 
obeyed  by  parallel  processes  executing  on  a time  varying  number  of  distributed  physical  processors.  For 
example,  some  of  the  processors  might  be  in  orbiting  satellites.  The  laws  are  Justified  by  appeal  to 
physical  intuition  and  are  to  be  regarded  as  falsifiable  assertions  about  the  kinds  of  computations  that 
occur  in  nature  rather  than  as  proved  theorems  in  mathematics.  The  laws  are  intended  to  be  used  to 
analyze  the  mechanisms  by  which  multiple  processes  can  communicate  to  work  effectively  together  to 
solve  difficult  problems. 

The  laws  presented  In  this  paper  are  intended  to  be  applied  to  the  design  and  analysis  of  systems 
consisting  of  large  numbers  of  physical  processors.  The  development  of  such  systems  is  becoming 
economical  because  of  rapid  progress  in  the  development  of  large  scale  integrated  circuits. 

We  generalize  the  usual  notion  of  the  history  of  a computation  as  a sequence  of  events  to  the  notion  of 
a partial  order  of  events.  Partial  orders  of  events  seem  better  suited  to  exprewing  the  causality 
involved  in  parallel  computations  than  totally  ordered  sequences  of  events  obtained  by  "considering  all 
shuffles"  of  the  elementary  steps  of  the  various  parallel  processes  [21,221  The  utility  of  partial  orders  is 
demonstrated  by  using  them  to  express  our  laws  for  distributed  computation.  These  laws  in  turn  can  be 
used  to  prove  the  usual  Induction  rules  for  proving  properties  of  procedures.  They  can  also  be  used  to 
derive  the  continuity  criterion  for  graphs  of  functions  studied  in  the  Scott-Strachey  model  of 
computation.  The  graph  of  a function  is  simply  the  set  of  all  input  output  pairs  for  the  function.  We 
can  prove  that  the  graph  of  any  physically  realizable  procedure  p that  behaves  like  a mathematical 
function  is  the  limit  of  a continuous  functional  F such  that 

graph(p)  > UkN  F<({}) 

In  other  words  the  graph  of  p is  the  limit  of  the  n-fokl  compositions  of  F with  itaetf  beginning  with  the 
empty  graph. 
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INTRODUCTION 


In  programming  language!  such  ai  SIMULA-67  [171  SMALLTALK  [181  and  CLU  [201  the  emphasis 
has  changed  (compared  to  Algol-60)  from  that  of  procedures  acting  on  passive  data  to  that  of  active 
data  processing  messages.  The  actor  model  is  a formalization  of  these  ideas  that  is  independent  of  any 
particular  programming  language.  Instances  of  SIMULA  and  SMALLTALK  classes  and  CLU  clusters 
are  actors.  However,  actors  have  been  designed  to  include  the  added  effects  of  parallelism  so  that 
instances  of  monitors[42,4!l  envek>pes[43l  and  serializers[15]  are  also  actors. 

The  actor  message  passing  theory  can  be  used  to  model  networks  of  communicating  processes  which 
may  be  as  close  together  as  on  the  same  LSI  chip  or  as  far  apart  as  on  different  planets.  It  can  be  used 
to  model  processes  which  communicate  via  shared  memory02l  packet-switched  networksU3,24l 
ring-networks[23l  boolean  n-cube  networks[44l  or  Batcher  sorting  nets(25l 


SECTION  III 


ACTORS  and  EVENTS 


The  theory  presented  in  this  paper  attempts  to  characterize  the  behavior  of  procedural  objects  called 
actors  (active  objects]  in  parallel  processing  systems.  Actors  and  events  are  the  fundamental  concepts  in 
the  theory.  Actors  interact  with  each  other  through  one  actor  sending  a messenger  to  another  actor 
called  the  target.  The  arrival  of  a messenger  at  a target  is  an  event,  and  these  events  are  the  basic 
steps  in  this  model  of  computation.  A key  point  in  the  actor  model  of  computation  is  that  messengers 
are  themselves  actors.  The  actor  model  is  therefore  an  un-typed  theory  which  is  a generalization  of  the 
A-cakulus  of  Church. 

Actors  can  be  created  by  another  actor  as  part  of  the  second  actor’s  behavior.  Indeed,  almost  every 
messenger  is  newly  created  before  being  sent  to  a target  actor. 

Events  mark  the  steps  in  actor  computations;  they  are  the  fundamental  interactions  of  actor  theory. 
Each  event  is  instantaneous  and  indivisible  taking  no  duration  in  time  Every  event  E consists  of  the 
arrival  of  a messenger  actor,  called  mets#nfer(E),  at  a target  actor,  called  tergeUE). 


We  will  often  use  the  notation: 


Et  £T  <«*»  M] 


to  indicate  that  E has  messenger  M and  target  T. 

The  time  of  an  event  is  the  arrival  of  the  messenger  of  the  event  rather  than  the  sending  of  the 
messenger  because  a messenger  cannot  affect  the  behavior  of  another  actor  until  that  actor  receives  it 
If  the  sender  wishes  a reply,  an  actor  (called  the  continuation)  to  whom  any  reply  should  be  sent  should 
also  be  carried  by  (as  a component  of)  the  messenger. 

Intuitively,  the  arrival  of  the  messenger  M at  the  target  T makes  M’s  information  available  to  the  target 
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for  the  purpose  of  activating  additional  events.  The  arrival  of  M at  T does  not  in  itself  cause  any 
change  to  either  M or  T. 

For  each  event  E we  define  acquaintanc*sE(T)  and  acquaintancasgfM)  to  be  the  vector  of  immediate 
acquaintances  of  T and  M,  respectively.  The  immediate  acquaintances  of  an  actor  x are  the  other  actors 
x directly  "knows  about"  at  a given  instant  The  relation  is  asymmetric  in  the  sense  that  it  is  possible 
for  an  actor  x to  know  about  an  actor  y without  it  being  the  case  that  y knows  about  x.  An  actor  may  or 
may  not  "know  about"  itself;  if  it  does,  it  can  directly  send  itself  messages! 

Lew  of  Finite  Acquaintenc— : For  all  actor*  x and  events  £ such  that  x is  the  tergal  or  messenger  of  E, 
the  vector  acquaintances^)  has  finite  length. 

The  above  law  states  that  an  object  can  only  be  directly  connected  to  finitely  many  other  objects. 

All  of  the  actors  which  are  definable  within  the  lambda  calculus  of  Church  have  the  property  that  their 
acquaintances  cannot  change  with  time,  i.e.  if  x is  defined  by  a lambda  expression,  then  for  all  events 
E|  and  E2  in  which  x Is  the  target  or  messenger,  it  wilt  be  the  case  that 

acquaint  ancosgjtx)  ■ acquaintances^!*) 

In  order  to  implement  interprocess  communication  between  parallel  processors  it  is  necessary  to  use 
actors  whose  vector  of  acquaintances  changes  over  time.  The  purpose  of  this  paper  is  to  axtomatlze  the 
fundamental  laws  which  govern  the  behavior  of  such  actors.  ' " 

An  important  example  of  an  actor  whose  immediate  acquaintances  change  with  time  is  a cell.  A celt  is 
an  actor  which  at  any  given  time  has  exactly  one  immediate  acquaintance-its  contents.  When  the  cell 
is  sent  a messenger  which  consists  of  the  message,  "what  is  your  contents?",  and  a continuation— another 
actor  which  will  receive  the  contents-the  cell  is  guaranteed  to  deliver  its  contents  to  that  continuation 
(while  also  continuing  to  remember  them).  All  this  might  be  very  boring  if  the  contents  of  the  cell  were 
constant.  However,  upon  arrival  of  a messenger  which  has  the  message  "update  your  contents  to  be  a" 
and  a continuation,  the  cell  is  guaranteed  to  update  its  contents  to  be  the  actor  x (whatever  that  may  be) 
and  inform  the  continuation  that  the  update  has  been  performed.  The  behavior  of  cells  will  be 
axiomatized  later  in  this  paper  after  we  have  presented  enough  of  the  actor  model  to  make  this 
possible. 

The  target(E)  and  the  messenger(E)  and  their  immediate  acquaintances  will  be  called  (immediate) 
participants  of  an  event  E.  The  immediate  participants  of  an  event  are  exactly  those  actors  which  can 
be  accessed  without  sending  any  messages. 

partlcipants(E)  a {target(E),  mesaenger(E)}  U acquaintancesE(target(E))  U acquaintances^messeng er(E)) 

Finite  Interaction  Lawt  For  each  event  E,  the  immediate  participants  in  E are  finite. 

The  above  law,  which  is  intended  to  capture  the  physical  intuition  that  only  finitely  many  Objects  am 
Interact  in  a single  event,  is  an  immediate  corollary  of  the  Law  of  Finite  Acquaintances. 
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SECTION  IV  — PARTIAL  ORDBRINQB  on  EVENTS 

In  order  to  develop  a useful  model  of  parallel  computation,  we  have  found  it  desirable  to  generalise  the 
usual  notion  of  the  history  of  a computation  as  a sequence  of  events.  In  this  paper  a history  of  a 
computation  will  be  expressed  as  a partial  order  which  records  the  causal  and  incidental  relations 
between  events.  The  partial  orders  constrain  the  maximum  amount  of  paralteHsm  that  can  be  used  in 
an  implementation.  Any  two  events  which  are  unordered  can  be  executed  concurrently  using  separate 
processors.  However,  there  is  no  requirement  that  an  implementation  do  this.  Events  can  be  executed 
in  any  time  sequence  that  is  consistent  with  the  partial  order. 


IVJ  - ACTIVATION  ORDERING 

One  important  strict  partial  ordering  on  events  In  the  history  of  a computation  is  derived  from  how 
events  activate  one  another.  Suppose  an  actor  xj  receives  a messenger  mj  in  an  event  E|  and  as  a 
result  sends  a messenger  to  another  actor  xj.  Then  the  event  E2.  which  is  the  arrival  of  the 
messenger  at  x^  is  said  to  be  activated  by  Ej.  We  call  the  transitive  closure  of  this  "activates* 
relation  the  activation  ordering  and  if  E|  precedes  E2  in  this  ordering  then  we  write 

Ej  E2 

In  general  -•«->  is  only  a partial  ordering  because  an  event  E might  activate  several  distinct  events 
E)^  thereby  causing  a "fork". 


IV -La  — Primitive  Actors 

A simple  example  which  illustrates  the  use  of  is  a computation  in  which  integers  3 and  4 are 
added  to  produce  7.  We  suppose  the  existence  of  a primitive  actor  called  ♦ which  takes  in  pairs  of 
numbers  and  produces  the  sum.  In  this  case  ♦ receives  a messenger  of  the  following  form: 

[rvqMM:  [3  4 J,  nply-f.  c] 

which  specifies  that  the  message  in  the  request  is  the  argument  tuple  [3  4]  and  the  reply  which  is  the 
sum  should  be  sent  to  the  continuation  e when  it  has  been  computed.  Thus  the  history  of  the 
computation  contains  two  events: 

L a request  event  with  target  ♦ and  messenger  that  specifies  the  numbers  to  be  added  and 
an  actor  c to  which  the  sum  should  be  sent; 


2:  a reply  event  with  target  c and  messenger  that  specifies  the  sum  of  the  numbers. 
These  two  events  are  related  as  follows  in  the  activation  ordering: 
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[♦  <•*  [3  4J,  nply-to:  efl 

I 

act 

I 

V 

[c  <—  [reply:  7fl 

The  activation  ordering  can  be  used  to  define  the  notion  of  a simple  primitive  actor  as  follows: 
Definition:  An  actor  x will  be  said  to  be  a simple*  primitive  actor  H whenever  an  event  E|  of  the  form 

[x  <**  [regsett:  m,  reply-to:  efl 

appears  in  the  Matory  of  a computation  then  there  la  a unique  event  E2  of  the  form 

|e  <»»  [reply:  rfl 

such  that  Ej  -oc»->  E2  and  there  are  no  events  E such  that  Ej  -eei->  E -ect->  E2. 

Complaint  processing  can  easily  be  incorporated  Into  the  scheme.  The  history  that  results  from 
dlvMo(3  0]  which  attempts  to  divide  3 by  0 is  shown  below: 

[divide  [request:  [3  0],  reply-fee  efl 

I 

act 

I 

V 

[c  <•»  [eompUiM:  [hthUtUk  31fl 

Since  complaint  processing  does  not  have  any  profound  implications  for  the  results  In  this  paper,  are 
will  not  say  anything  more  about  the  matter. 

The  history  of  the  computation  of  fsctoria([3]  using  an  iterative  implementation  of  factorial  illustrates 
how  the  activation  ordering  can  be  used  to  illustrate  properties  of  control  structures.  We  will  suppose 
that  factorial  knows  about  an  actor  called  loop  which  is  sent  tuples  of  the  form  [index  product]  where  the 
initial  index  Is  3 and  the  initial  product  is  1.  Whenever  loop  receives  a tuple  [index  product!  where  Index 
is  not  1,  then  it  sends  itself  the  tuple  [(index  - 1)  (index  o product)]. 


It  Later  in  this  paper  wo  wW  see  examples  of  primitive  actors  such  as  fork  and  Join  primitives  which  o re  not 
simple. 
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[factorial  <«“  [nfH«:  [3J,  rtpiy-to:  cQ 

I 

act 

I 

V 

[loop  <•»  [reqeaif;  [3  1J.  npljrio:  cfl 

I 

act 

I 

V 

[loop  [rapMiC  [2  3J,  rtply fa:  cfl 

I 

act 

I 

V 

[loop  <••  [npuN:  [1  •],  rtpty-to:  cfl 

I 

act 

I 

V 

[c  <—  [reply:  6fl 

The  actor  loop  is  iterative  because  it  only  requires  the  amount  of  working  stored  needed  to  store  the 
index  and  product  Note  that  only  one  reply  is  sent  to  the  continuation  c even  though  c appears  as  the 
continuation  in  several  request  events. 


IVJ.b  — Laws  for  the  Activation  Ordering 

It  is  not  possible  for  there  to  be  an  infinite  number  of  events  in  a chain*  of  activation  between  two 
given  events  in  the  activation  ordering  of  the  history  of  a computation.  This  law  implies  the  existence 
of  primitive  actors.  Stated  more  formally, 

Law  of  FinHa  Activation  Chains  balwaan  two  Evanitt  If  C is  a chain  of  evants  in  the  activation  ordering  from 
E}  to  E2t  than  C is  finite. 

The  laws  of  finite  activation  chains  is  intended  to  eliminate  "Zeno  machines"-i.e.  machines  which 
compute  infinitely  fast.  For  example,  consider  a computer  with  your  favorite  instruction  set  which 
executes  its  first  instruction  in  1 microsecond,  its  second  in  1/2  microsecond,  its  third  in  1/4  microsecond, 
and  so  on.  This  machine  not  only  could  compute  everything  normally  computable  in  leu  than  2 


J 


2t  The  careful  treatment  of  the  storage  required  for  this  oxamplo  Is  given  in  [21]. 
3:  A chain  is  a totally  ordered  sequence  of  events 
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microseconds,  but  could  also  solve  the  ’halting  problem*.  It  could  do  this  by  simulating  a normal 
computer  running  on  some  input,  and  if  the  simulation  were  still  running  after  2 microseconds,  it  could 
conclude  that  the  simulated  machine  does  not  halt  on  that  input 

Intuitively  each  event  can  directly  activate  only  a finite  number  of  ocher  events.  The  events  directly 
activated  by  an  event  E are  called  immediate  successors  of  E (under  the  activation  ordering  ~*et->).  The 
Immediate  successor  set  of  E in  the  -#«»->  ordering,  written  Immediate-wet . ^ (El  can  be  defined 
formally: 

iiwne<fiate-*ucc.ae(_}(E)  a |Ej|  E ~act->  Ej  and  "O  Eg  such  that  E *ec»->  Eg  -wet->  Ej| 

Then  we  have  the  following  law: 

Law  ol  Finite  Immediate  Successors  In  the  Activation  Orderlntt 
For  all  events  E,  the  set  immadiat#-*uc«_oc,_>(E)  la  finite. 

We  define  immediate  predecessors  in  the  activation  ordering  in  a manner  similar  to  that  used  for 
Immediate  successors.  We  postulate  that  an  event  is  either  an  initial  event  in  which  case  it  has  no 
predecessors,  or  it  is  activated  by  a unique  predecessor  event 

Law  of  Uniqueness  of  Immadiala  Predecessors  In  the  Activation  Orderint: 

For  all  events  E,  the  set  immediate-pred.aet.>(E)  has  at  most  one  element 

This  law  is  based  on  the  physical  intuition  that  two  distinct  events  cannot  both  be  the  immediate  cause 
of  another  event  This  is  because  an  event  which  immediately  activates  another  event  must  have  been 
the  sender  of  the  messenger  for  that  second  event  Thus  each  event  E has  at  most  one  activator4 
which  if  it  exists  will  be  denoted  as  activator(E). 

Note  that  the  activation  ordering  analyzes  the  causality  of  the  classical  "fork-join*  structure  of  parallel 
computations  in  an  asymmetric  manner.  The  reason  is  that  the  last  event  to  arrive  at  the  Join  is  the  one 
which  activates  the  remainder  of  the  computation.  Later  in  this  paper  we  will  introduce  another  partial 
order  on  events  [called  the  continuation  order]  which  treats  "fork-join"  control  structures  in  a symmetric 
fashion. 


4:  This  usage  of  the  term  "activator"  is  somewhat  in  conflict  with  the  usage  of  the  term  in  Creif  and 
Hewitt[40].  The  usage  here  has  the  advantage  that  it  is  more  firmly  grounded  in  the  physics  of 
computation. 
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1V.2  - ARRIVAL  ORDERINGS 


Intuitively,  the  activation  ordering  can  be  identified  with  ’causality"  in  which  each  event  is  ’caused'  by 
its  activator.  However,  the  activation  ordering  is  not  enough  to  specify  the  actions  of  actors  with 
’side-effects’,  such  as  cells.  For  this  reason,  we  introduce  the  arrival  ordering  for  an  actor  x 

whose  behavior  depends  on  the  order  of  arrival  of  the  messengers  sent  to  x.  The  physical  basis  for 
defining  the  order  of  arrival  is  a hardware  device  called  an  arbiter.  Note  that  there  are  only  a few 
primitive  actors  such  as  cells  and  synchronization  primitives  whose  behavior  actually  depends  on  the 
order  in  which  messengers  arrive. 

Due  to  the  totality  of  the  order  of  arrival  of  messengers  at  an  actor  x (which  will  be  discussed  in  more 
detail  below),  the  notion  of  a "local  time"  for  x is  well-defined.  Therefore,  when  talking  about  a single 
actor,  we  can  talk  rigorously  about  the  changes  in  its  vector  of  acquaintances  over  time 


IV.2a  — Laws  for  Arrival  Orderings 

The  arrival  ordering  for  each  actor  x is  required  to  be  a total  ordering  on  alt  events  which  have  x as 
their  target  This  policy  is  enforced  by  arbitration  in  actors  such  as  synchronization  primitives  which 
need  to  observe  the  in  order  in  which  their  messages  arrive. 

Arrival  Ordrint  Law:  ?(  Ei^Eg  ,n<*  targeWEiMargailEgkw, 
then  with*-  E;  ~nn~>%  E2  or  Eg  -orr“>x  Ej 

This  law  says  that  the  messenger  of  Ej  arrives  at  x before  the  messenger  of  Eg  or  vice-versa. 

Note  in  connection  with  arrival  orderings  that  there  is  no  necessary  relation  between  the  arrivals  of  two 
messengers  at  a target  and  the  ordering  of  their  activator  events.  Suppose  that  events  Ej  and  Eg  have 
the  same  target  x.  Then,  in  general,  the  circumstance  that  Ej  -«rr*>x  Eg  does  not  imply  that 
Ej  Eg  since  E*  ana  Eg  might  be  distinct  events  of  two  asynchronous  processes  that  both  happen 
to  send  messengers  to  the  same  actor.  Furthermore,  the  fact  that  aetivatoKE})  -oet->  activator  (Eg)  is  no 
guarantee  that  Ej  -*rr->x  Eg;  l.e.  the  messenger  of  Eg  might  still  arrive  at  the  target  actor  before  the 
messenger  of  Ej. 

Given  an  event  Ej  of  the  form  CT  Mjl  and  an  event  Eg  of  the  form  £t  MgJ,  there  are  only  a 
finite  number  of  events  between  these  two  events  in  the  arrival  ordering  -on->y.  Stated  more  formally: 

Corollary:  law  of  Finite  Chains  between  two  Eventa  In  an  Arrival  Ordering: 

For  ail  eventa  Ej  and  Eg  such  that  targat(E^)  ■ targat(Eg)  ■ x, 

{E|  Ej  -«rr->x  E -arr-'>%  Eg}  is  finite. 

This  eliminates  anomalous  behavior  like  the  following:  a cell  receives  the  infinite  sequence  of  ’store" 
messages:  [store:  1],  [more:  1/2],  [store:  1/4],  [store:  1/S],  etc  and  then  receiving  a "contents?"  message. 
What  is  it  to  reply?  Zero?  But  zero  was  never  explicitly  stored  into  the  cell! 
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LmJT,L0f  F'nite  CI’ainS, ,n  the  ArrlVal  °rder,n?  a,,ow*  UJ  to  define  immediate  predecessors  and 
immediate  successors  for  the  arrival  ordering  in  a manner  similar  to  the  one  used  for  the  activation 

over' Tts*  domain*6  ^ °r6^ln^  Laws  *uarantee  that  the  arrival  ordering  for  each  actor  is  total 
o er  its  domain,  successors  and  predecessors  are  unique  when  they  exist  If  an  event  r hat  an 

immedU.predecessor  In  -orr-Wt(E)  then  it  wi„  he  tiled  the  praJJ^E  iTJEJLS  by 

SECTION  V — CREATION  of  ACTORS 

!„t:r,ya.the,Creatl0n  * *Z  aCt°r  * mUSt  Preccde  anf  use  °f  *•  I"  order  to  precisely  state  the  above 
tL  th  W'^UU  ^ more  prec,se  about  when  actor*  «•  created.  For  eacl/actor  x which  is 
cau«,"o£  c™'.S  ’ C°°’P““U0"'  sh>"  rw,ulre  «»■  «*•  1>  • »»!<,«.  e,«m  crwattonU)  which 

Let  created(E)  be  the  set  (possibly  empty)  of  actors  created  by  the  event  EH*  the  set  of  actors  which 

claim  E as  their  creation  event.  Note  that  x is  not  a participant  in  creation(x)  because  x does  not  mow 

into  existence  until  after  cr.ition(x)  has  occurred  ' Decause  x does  not  come 

P*finitions  ereated(E)  a {x|  crestk>n(x)-E} 

The  intuition  that  a single  event  can  only  create  finitely  many  objects  is  formalized  as  follows: 

Uw  of  Finite  Creation*  For  oieh  event  E,  creited(E)  it  finite. 

If  an  acto  x is  created  in  the  course  of  a computation,  then  prior  to  any  riven  message  whirh 

receives,  it  c >uld  only  have  received  finitely  many  messaged  P J * *h,Ch  “ 

L«w  of  Finitely  Many  Predecessors  in  the  Arrival  Qrderint  of  a Create 

If  an  actor  x ia  created  in  the  course  of  • computation  and  target(E)  « x then 
{El  E'  -arr->%  E}  i,  finite. 

Jfha  cSl  u we'll  1X0?  Th  TXt  SeCti°n  t0  gUaRlntee  that  our  ax,om  whlch  characterizes  the  behavior 
or  a cell  is  well  defined.  The  law  guarantees  that  the  process  of  repeatedly  takinr  the  Drecuruir  nr  >n 
*""*  with  B,g«  t Will  find  ,h,  aaam  for , l,Mu  « “ 
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SECTION  VI  — CELLS 


VII  — Axiom  for  Cells 

The  axiom  for  cells  has  two  parts:  involving  their  creation  and  use  which  can  be  stated  as  follows: 

Creation:  There  is  a simple  primitive  actor,  ailed  create-cell,  such  that 
whenever  it  is  sent  a tuple  of  the  form  [I],  it  crates  an  actor  • which  is  a new 
storage  cell  with  initial  contents  the  actor  I.  More  formally,  for  ach  event  Ej 
of  the  form  Eji  [create-cell  <•»  [request:  [i],  reply- to:  efl  there  is  a unique 
event  E2  of  the  form  E2t  [c  <««  [reply:  «JJ  such  that  • is  a newly  crated 
simple  primitive  actor  and  Ej  ■ activator^)-  Furthermore  craatad(E})  ■ (a) 
which  says  that  the  only  actor  crated  by  the  event  Ej  is  the  storage  all  a. 

Thus  ach  storage  cell  that  is  returned  by  create-cell  differs  from  all  previously 
crated  cells.  The  storage  all  a always  has  exactly  one  acquaintana  which  is 
initially  i.  If  E is  an  event  which  has  a as  its  target,  we  will  use  the  notation 
contentsgU)  to  denote  this  acquaintana  at  the  time  of  the  event  E. 

Use:  A storage  all  a an  only  be  sent  messages  of  the  form  [commi*?]  which 
requests  the  "current"  contents  and  [updoia:  x)  which  updates  the  contents  to  be 
x. 

The  contents  of  a when  it  receives  one  of  these  messages  in  an  event  E can  be 
axiomatized  using  the  arrival  ordering  for  a as  follows: 

conlontagls)  a 

If  E ha*  a precursor  in  the  arrival  ordering  for  a 
then 

if  precursor (E)  it  of  the  form  [a  <*'*'  [request:  [update:  x],  reply- to: 
then  x 

else  contantiprc<Unor(E)(') 
else  I which  it  the  actor  ten 1 10  create-cell  10  create  a 

If  E is  an  event  of  the  form  [a  <**  [request:  [contents?]  replyto:  cfl  then  there 
is  a unique  event  V of  the  form  E*t  [c  <«~  [reply:  eontent«E(a)fl  such  that 
E > activator (D. 
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vi.g  — Busy  Waiting 

Bu^y  waiting  is  the  kind  of  waiting  used  in  some  multi-processing  systems.  In  this  kind  of  waiting,  the 
contenu  of  a cell  is  continually  checked  and.  if  it  is  unchanged,  the  processor  branches  back  to  check  it 
again.  This  kind  of  waiting  Is  used  when  one  processor  cannot  depend  upon  another  to  "wake  it  up* 

when  the  contents  change.  Busy  waiting  depends  upon  the  property  of  Finite  Chains  between  Events  in 
the  arrival  orderings  of  cells. 

For  example  suppose  that  a new  storage  cell  a is  created  whose  initial  contents  are  0.  Furthermore 
suppose  that  the  contents  of  • are  updated  exactly  once  by  a process  which  sends  a the  message 
[update:  IJ.  Now  another  process  might  busy  wait  until  the  contents  of  the  ceil  c change  to  ibv 
executing  a procedure  of  the  following  form:  6 7 


loop:  If  cont«nta(s)  ■ 0 

(ton  goto  loop 
elte  ...procoocL. 

Theproperty  of  Finite  Chains  between  Events  in  the  arrival  ordering  for  ,,  guarantees  that  the  code 
-proceed...  will  eventually  be  executed  since  otherwise  there  would  be  an  infinite  number  of  "contents?" 
messages  before  the  [update:  1]  message  in  the  arrival  ordering  of  a 


The  up-  of  the  arrival  ordering  in  the  actor  model  of  computation  seems  to  help  overcome  one  of  the 

m 0trhW  the°rte*  °!  thC  SmanticJ  of  <»mimm*atlng  parallel  processes  based  on  the 
^ °f  Comfutatlon  The  Scott-Strachey  model  is  a deep  mathematical  study  of 

nctions  that  are  minimal  fixed  points  of  "continuous"  functionals.  As  currently  developed  the 
Scott-Strachey  model  seems  to  be  a special  case  of  the  actor  model  in  that  it  only  deab  with  actors  which 
,lke  mathematical  functions  to  the  exclusion  of  actors  such  as  cells  and  synchronization 
primitives  whose  behavior  strongly  depends  on  the  arrival  ordering  of  messages  sent  to  the  actor 


SECTION  VII  — LAWS  of  LOCALITY 


We  would  like  to  formalize  the  physical  intuition  that  computation  to  local  and  there  can  be  no 
at  a distance  . The  laws  of  locality  presented  in  this  section  are  intended  to  capture  these 


intuitions. 


The  initial  acquaintances  of  an  actor  are  a subset  of  the  participants  in  its  creation 
created  by  its  creation  event: 


event  and  the  actors 


Initial  Acquaintances  Lew:  If  an  actor  a ia  the  target  of  an  event  E 
such  that  E it  the  first  event  in  the  arrival  ordering  of  a then, 

acquaintances^)  g psrticipants(ereation(s))  U created(creetion(z)) 


The  acquaintances  of  an  actor  can  increase  over  its  previous  acquaintances  only  by  the 
the  messengers  which  it  receives  ani  the  actors  which  it  creates. 


acquaintances  of 
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Pfcurtor  Acqueinlencoc  Lew:  If  an  actor  z it  tho  target  of  an  ovont  E 
auch  that  E hat  a procurtor  in  tho  arrival  ordering  of  z than, 

acquaintances^)  C partlcipant»(pracurtor(E))  U created(precuraor(E)) 

An  actor  x can  only  be  the  target  or  messenger  in  an  event  E if  x is  newly  created  or  is  an  immediate 
participant  in  activator(E). 

Activator  Acquaintances  Law:  For  each  event  E which  is  not  an  initial  event 
terget(E)  < perticipants(actlvator(E))  U created(activator(E)) 
mwaenger(E)  « participants(activator(E))  U crestod(activator(E)) 


SECTION  VIII  ~ COMBINED  ORDERING 

To  make  sense  out  of  the  activation  and  arrival  orderings,  and  to  relate  them  to  a notion  of  "time",  we 
introduce  the  precedes  relation 

Definition:  — > is  a binary  relation  on  events  which  is  the  transitive  closure  of  the  union  of  the 
activation  ordering  -aet->  and  the  arrival  orderings  -*nr->x  for  every  actor  x. 

In  order  for  -->  to  function  as  a notion  of  precedence,  we  require  that  the  activation  and  arrival 
orderings  be  consistent.  This  is  guaranteed  by  the  Law  of  Strict  Causality  for  actor  systems  which 
states  that  there  are  no  cycles  allowed  in  causal  chains;  i.t  it  is  never  the  case  that  there  is  an  event  E in 
the  history  of  an  actor  system  which  precedes  itself.  Stated  more  formally  the  law  of  causality  is  that 
the  combined  ordering  is  also  a strict  partial  ordering: 

Law  of  Strict  Ceussllty:  For  no  ovont  E does  E—>E. 

Suppose  that  we  have  events  in  a computation  described  as  follows: 

Ej:  [x  mjJ 

E2:  [y  <***'  m2] 

E3:  [y  mjl 

Eg:  [ x mgj 

Ej  -aet->  E2  {arrival  of  mj  at  x causes  tho  arrival  of  n^  at  y 
Ej  •«rr->y  Ej  »m2  arrives  at  y before  m3 
E3  -aci->  Eg  {arrival  of  m3  at  y causes  the  arrival  of  mg  at  x 
Eg  -*rr->x  Ej  (mg  arrives  st  x before  mj 

The  Law  of  Strict  Causality  states  that  the  history  of  the  computation  given  above  is  physically 
impossible  to  realize  even  though  it  Is  locally  reasonable  in  the  sense  that  any  proper  subset  of  the 
orderings  can  be  realized.  The  above  example  of  an  impossible  computation  Is  due  to  Guy  Steele. 

Now  we  can  define  immediate  predecessors  and  successors  of  an  event  E under  — >.  Note  that  an  event 
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[t  mj  has  at  most  two  immediate  predecessors  in  the  relation  —>  one  of  which  is  the  activator  of 
the  event  and  the  other  is  the  precursor  of  the  event 

We  would  like  to  formalize  the  intuition,  that  between  any  two  events  which  are  causally  related,  that 
there  are  only  finitely  many  events  in  a causal  chain  that  connects  the  events.  This  intuition  is 
formalized  in  the  following  law: 

law  of  Finite  Chains  between  events  in  ito  Combined  Ordering 

Th#r*  era  no  infinite  chains  of  events  between  two  events  in  the  strict  parti  si  ordering  — >. 

We  can  use  the  combined  ordering  — > to  express  an  Important  law  about  created  actors. 

Law  of  Creation  before  Uses 

If  an  actor  x is  crested  in  the  course  of  s computstion  end  E is  an  event  with  target  x then 
creation  (x)  — > E 


VIII.l  - NESTED  ACTIVITIES 

Since  one  of  the  aims  of  actor  theory  is  to  study  patterns  of  passing  messages,  we  must  identify  several 
common  patterns.  The  two  most  common  types  of  messengers  are  requests  and  replies  to  requests.  A 
request  has  two  acquaintances:  the  request  message  itself,  and  a continuation  actor  which  is  to  receive 
the  reply.  A reply  to  a request  consists  of  a message  sent  to  the  continuation;  this  reply  usually  contains 
an  answer  to  the  request,  but  may  contain  a complaint  or  excuse  for  why  an  answer  is  not  forthcoming. 

We  define  the  nested  activity  corresponding  to  a request  event  RQ  in  a computation  to  be  the  set  of 
events  which  follow  RQ  in  the  combined  order  but  precede  any  reply  RP  to  the  request  More  formally, 
let  E— fc  denote  the  set  of  events  which  follow  E (including  E itself)  and  —fcE  denote  the  set  of  events 
which  precede  E (including  E)  in  the  computation.  Then 

activity(RQ)  a RQ—fc  f|  Uf—fcRP  | RP  is  reply  to  RQ) 

Activities  embody  the  notion  of  the  nesting  of  activities  that  is  produced  by  conventional  programming 
languages,  since  we  only  include  those  events  In  an  activity  which  contribute  to  a reply  to  that  request 
Note  that  If  no  reply  is  ever  made  to  the  request  RQ  in  the  computation,  then  the  activity  corresponding 
to  RQ  is  incomplete  and  therefore  vacuous. 

If  we  let  concurrent  activitioe  be  those  whose  request  events  are  unordered,  then  concurrent  activities  may 
overlap— i.e.  share  some  events.  However,  this  can  only  happen  If  the  activities  involve  some  shared 
actor  which  is  called  upon  by  both;  if  two  concurrent  activities  Involve  only  "pure"  actors  which  by 


5i  Thic  law  is  t strict  generalization  of  the  Law  of  Finite  Chains  between  events  in  the  Activation  Ordering,  the 
Law  ef  Finite  Chains  between  events  in  each  Arrival  Ordering,  and  the  Law  of  Strict  Causality.  We  conjecture 
that  the  Law  of  Finite  Chains  between  events  in  the  Combined  Ordering  can  be  proved  using  the  Laws  ef 
Locality.  If  this  conjecture  is  established  then  we  would  no  longer  need  ft  as  an  an  independent  law. 
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definition  have  no  arrival  ordering  and  can  be  freely  copied  to  avoid  arbitration  bottleneck*,  then 
activities  are  properly  nested,  meaning  that  two  activities  are  either  disjoint,  or  one  is  a subset  of  the 


The  notion  of  activities  allows  one  to  vary  the  level  of  detail  in  using  actors  to  model  a real  system.  Let 
us  define  a primitive  activity  as  the  activity  of  a request  which  activates  exactly  one  immediate  reply, 
with  no  events  intervening.  Thus,  a primitive  activity  always  consists  of  exactly  two  events.  A crude 
model  for  a system  might  represent  an  actor  at  primitive,  t.e.  one  whose  receipt  events  are  ait  primitive 
However,  at  a finer  level  of  detail,  one  might  model  the  Internal  workings  of  the  actor  as  an  activity  in 
which  a group  of  *sub“-actors  participate. 


SECTION  IX  — CONTINUATION  ORDERING 

The  notion  of  nested  activities  can  be  used  to  help  explicate  several  of  the  various  notions  of  “process" 
that  have  been  used  in  computer  science.  In  particular  it  can  be  used  to  define  an  ordering  on  events 
that  is  important  to  defining  the  semantics  of  programming  languages  for  parallel  processing.  This 
new  ordering  is  the  continuation  order  and  will  be  denoted  by  ~coium>.  The  continuation  ordering  is 
important  because  it  captures  the  usual  operating  system  notion  of  "process"  in  terms  of  partial  orders 
on  events.  Later  in  this  paper  we  will  show  how  to  use  the  continuation  ordering  to  provide  a precise 
characterization  of  the  relationship  between  the  Scott*Strachey  model  and  the  actor  message-passing 

OetWtion*  If  E and  P are  events  than  E -com->  F If 
It  Thera  la  some  activity  a aueh  that  E,  P « a 
and 

2t  E — > F 

Note  that  each  event  has  only  finitely  many  predecessors  and  finitely  many  immediate  successors  in  the 
continuation  ordering  because  9eont>>  is  4 sub-ordering  of  ■•>. 


IX.1  — Fork-Join  Behavior 

In  programming  languages  for  parallel  processing,  it  is  quite  common  to  provide  primitives  by  which 
processing  can  "fork"  creating  more  parallelism  which  can  later  Join  together.  Parallel  evaluation  of  the 
arguments  of  a procedure  provides  a good  example  of  fork- Join  behavior.  All  fork-join  primitives  have 
the  **"*  structure.  Consider  for  example,  the  behavior  of  a procedure  I which  computes 
(a  ♦ yz)  given  arguments  % and  y.  Below  are  the  two  possible  histories  for  an  activity  of  f which 
produces  these  results  where  — > is  used  for  the  combined  ordering: 
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Ejt  [(  <•*  [nfMil.1  [k  yj,  reply- le:  efl 

I I 

-act act 


Eji  [*  <*"  [requett:  [x  xj,  replyto:  ‘ill 


act 

I 

V 

Eg!  |«i  <— ' [reply:  *2fl 


E31  [•  <•*  [nfMX:  [y  y|*  reply-ie:  ejfl 

I 

act 


T 

Eg:  C«2  <*~  [reply:  y2!! 


I I 

V V 

Eft  [♦  <**  [nfMX:  (x2  y2!  repty-tm  efl 

I 

act 


V 

Ey,  [e  <**  [reply,  (x2  ♦y*)a 


Note  that  in  the  history  given  above  that  Eg  -ect->  Eg  whereat  in  the  hiitory  given  below  that 
Eg  ■act-)  Eg. 


E|t  [f  <•»  [rafwii:  [x  yj,  reply-te:  efl 

I I 

-act — -———act—— 


Eg*  C*  <*'*'  [regaetl:  [x  xj,  replyte:  ‘ia 

1 

act 


Eg!  [*  <•«  [y  yj,  reply**  egfl 

I 

act 


a 

Egi  [tj  <««  [reply:  x^fl 


T 

Eg*  [e2  <""  [reply  y*fl 


I I 

V V 

Egt  [♦  <»«*  [regaeti:  [x2  y2],  reply-let  efl 


▼ 

Eyi  [c  <~  [reply  (x2  + y2)fl 
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We  shall  say  that  Ej  is  a fork  event  and  that  Eg  is  a join  event.  In  the  above  computation  it  will 
necessarily  be  the  case  that  Ej  -aei->  Eg  since  this  is  the  only  way  that  Eg  can  be  activated.  Therefore  it 
will  be  the  case  that  either  Eg  Eg  or  Eg  Eg.  The  continuation  ordering  -coni->  enables  us 
to  present  the  history  of  the  computation  without  having  to  be  concerned  as  to  which  of  the  above 
possibilities  actually  occured.  Using  the  continuation  ordering  the  symmetry  of  the  above  fork-join 
computation  is  demonstrated  by  the  fact  that  the  continuation  ordering  is  the  same  for  both  of  the 
above  histories: 


Ej«  [I  <—  [a  yj,  rwply-to:  efl 

I I 

-cont — — cont 


I 

V 

^2*  t*  <"~  [a  *1  nply-to:  c.fl 

I 

cont 

I 

V 

E4j  [cj  <•«  [reply;  x2JJ 

I 


I 

V 

Egt  I*  <—  [y  y],  nply-to:  e2fl 

cont 

I 

V 

E5t  [t2  <*»  [rtply:  y^fl 


cont- 


I 

V 


-cont- 


I 


Eft  £♦  <y  [reoaest:  [x2  y2J,  npljrto:  efl 

cont 

I 

V 

E7:  [c  <•»  [reply:  (a*  ♦ y*)JJ 


IX.2  — 8ynohronl»fctlon  Between  Prooosooo 

The  behavior  of  semaphores  provides  a simple  example  to  illustrate  the  relationship  between  the 
activation  and  continuation  orderings.  Suppose  that  s is  a newly  created  semaphore  whose  capacity 
(count)  is  initially  0 so  that  the  first  attempt  to  perform  a P operation  will  wait  until  a V operation  is 
performed  on  the  semaphore.  In  order  to  model  the  behavior  of  semaphores  using  message  passing,  we 
will  suppose  that  P and  V operations  are  implemented  by  sending  [P:J  and  [F;J  requests  respectively. 
Suppose  that  Ep  is  the  first  event  in  the  arrival  ordering  of  s in  which  ■ receives  a [P;J  request  and  Ey 
is  the  next  event  in  which  a receives  a [P:J  request  The  activation  and  continuation  relations  between 
these  events  is  shown  below: 
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Epi  [•  <~~  [r*qii0«i:  IP:),  reply-to:  «.fl 

I 

cont 

I 

V 

Et  [ct  <—  I reply.  -JJ  <-8ct-  Eyi  [»  <—  [rafuii:  IF:),  reply**:  ejfl 

cont 

I 

V 

E«2  <**  I »p*r  -0 

Note  that  Ey  — > E since  Ey  -«*»->  E but  It  is  not  the  case  that  Ey  -e#nt->  E because  there  is  no  activity  in 
they  are  both  elements. 
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X I — Behavior  of  Prooodar— 

In  this  section  we  would  like  to  characterize  the  behaviors  of  actors  which  behave  like  procedures.  In 
order  to  do  this  we  would  like  to  use  the  notion  of  an  activity. 

To  make  our  discussion  more  concrete  we  will  consider  the  behavior  of  an  implementation  of  the 
Fibonacci  function  defined  as  follows: 

(fib  n)  e 

«/ 

(n  ■ 1)  then  1 
(n  ■ 2)  the  it  1 

<n  > 2)  then  ((fib  (n  - 1))  ♦ (fib  (n  - 2)))) 

The  following  history  is  a partial  order  of  some  of  the  events  that  might  result  from  evaluating  (fib  4). 
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I 

I 

V 


El*  c«b  <*•*  [nfMik  [4J,  rtply-10:  efl 

I I 
I I 

-cont cont 


Ej*  | fib  <—  [nfHd.  [3J,  nplyto: 


I 

cont 

I 

V 

E4I  [cj  <—.  [nply.  231 

I 

cont — 


I 

I 

V 

C3*  [«b  <«~  I2J,  nply-to:  e,J| 

I 

cont 

I 

V 

£5*  fc2  <«~  [nply.  Ifl 


I 

I 

V 


-cont- 


I 


E*»  [♦  <—  [rt9M«t:  [2  1J,  rtply-f  : efl 


I 

cont 

I 

V 

E7*  £e  <**  [rtpljr,  3fl 

2Z2Z&ZI  1 2H£?sr  co"“'* - -** <—  « *» .)», 


0*  {Kfib  <■  3)  ->  2|} 
yt  (Kfib  <*  2)  —>  If} 

The  activity  ff  has  events  which 
in  the  diagram  below: 


•tsrttf) . E2  «nWi(^).E4 

•fertfir)  ■ E3  fhWsM?)  - Eg 

are  not  shown  in  the  above  diagram.  Some  of  these  events  are  shown 


I 
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^2*  [»b  <»«*  [rafMrt:  [31  reply* k c<]] 

II 


-cont- 


I I 


I 
I 

V 

Egt  [fib  <•»  [rwfiMif:  [2J,  replyto:  egfl 

cont 

I 

V 

CiO<  t*3  <“~  [r»pfys  lfl 


•cont- — 

I 

I 

V 


I 

I 

V 


•cont* 


I 

I 

V 

Egt  [fib  <•»  [rtywiti  [11  reply-**:  CgQ 

I 

cont 

I 

V 

En*  Ce4  <*•  Wr  ifl 


-cont- 


E|2>  [♦  <—  [1  11  replyte:  eafl 

I 

cont 

I 

V 

Eg:  [ej  <—  [reply;  2fl 


Thus  we  see  that  0 In  turn  has  sub-activities  y'  and  I such  that 


y't  {((fib  <■  [2])  ~>  1|}  atart(<y’)  • Eg  fWsh(<y’)  ■ E10 

l’t  {|(flb  <«  [1J)  ~>  l|}  start  (J')  > Eg  ftfWth(J’)  ■ Eu 

Notice  that  both  y and  y'  both  satisfy  the  partial  description  {|(fib  <■  [2])  — > 1|)  even  though  they  are 
distinct  activities  which  share  no  events  in  coimnon.  Uniquely  identifying  activities  has  the  same 
problems  at  uniquely  identifying  objects  and  events:  no  finite  local  description  will  serve  as  a unique 
identification. 
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An  actor  » will  be  said  to  behave  like  a procedure  if  the  following  conditions  hold  for  all  the  histories 
of  f: 

It  AH  of  the  moaaongora  of  events  in  the  history  are  either  requests  or  replies. 

2t  There  is  at  most  one  reply  event  E to  any  given  continuation  actor  in  a history  of  f.  Furthermore 
such  an  event  must  be  an  element  of  the  activity  of  a request  event  of  the  form 
[...  <~~  [r«K7u«ji: ...,  reply-io:  cj]  and  every  such  request  event  must  be  an  element  of 
predoceeoorsaaMl.>(E). 

3t  The  activities  of  f are  property  nested  II.  for  any  two  activities  of  f it  is  the  caae  that  either 
one  activity  is  a proper  subset  of  the  other  or  the  two  activities  are  disjoint. 


X.2  — Limit*  of  Continuous  Funotlonnla 

The  actor  model  of  computation  is  based  on  axlomatizlng  the  causal  and  Incidental  relations  among 
computational  events.  The  Scott-Strachey  model  of  computation  is  based  on  the  mathematical  analysis 
of  continuous  function  spaces.  Superficially  these  two  models  might  seem  to  have  little  in  common.  In 
this  section  we  will  analyze  the  relationship  between  these  models  of  computation.  Our  main  result  is 
that  if  an  actor  behaves  like  a mathematical  function  then  it  is  the  limit  of  a continuous  functional  in 
the  sense  of  Scott  This  result  follows  from  the  law  that  each  event  has  only  finitely  many  immediate 
successors  in  the  continuation  ordering  and  the  law  of  finite  chains  between  two  events  in  the 
continuation  ordering. 

Once  again  we  will  make  the  discussion  concrete  by  considering  the  behavior  of  an  implementation  of 
the  Fibonacci  function  defined  by  the  following  procedure 

(fib  n)  a 

(n  ■ 1)  the*  1 
(n  ■ 2)  (ton  1 

(n  > 2)  iton  ((fib  (n  - 1))  ♦ (fib  (n  - 2)))) 

Definition:  Suppose  f behaves  like  a mathematical  function  and  that  <x  yXf  and  <x'  y*Xf. 

Than  <*’  y*>  wifi  be  said  to  be  an  Immediate  f -defendant  of  <x  y>  If 
there  it  tome  history  of  f which  has  events  Ej  and  E2  of  the  form 
Ejl  (f  <•*»  [request:  X,  reply-to:  ...fl 
Ejt  [f  <•*'  [request:  re  ply  to:  ...fl 

such  that  Ej  — > E2  and  it  It  not  the  case  that  there  Is  an  event  E of  the  form 
Ei  [f  [request:  repiy-to:  41 
such,  that  E}  -con«->  E -cenl->  E2 

For  example  <2  1>  is  an  immediate  fib-descendant  of  <3  2>. 
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Definition:  Suppose  that  <x  yXf 

immed»ate-deecsndentfy«i  y»  ■ {<*’  y*>l  <*'  y*>  Is  an  Immediate  f-daecandswt  of  <x  y>) 
lnwnodiato-descondantsf|b(<l  1>)  a {} 

ifiwnediate~descendantefjb(<2  1>)  * 0 

immediate-descendantsfjb(0  2>)  a {<1  1>  <2  1>J 
immediato-doscondantSfi^O  5»  a {<3  2>  <4  3>} 

Lemma:  If  f behaves  like  a mathematical  function  and  <x  yXt  then  ImmadWa-danandenUylO:  y»  is  finite. 

Proof:  Follows  from  the  Law  of  Finitely  Many  Immediate  Successors  in  the  Activation  Ordering. 

Definition:  If  G is  s sot  of  input-output  pairs  then 

Df(G)  s (<x  y>|  <x  yXf  and  immodisto-doscendantSf(<i  y>)  e G} 

Intuitively  Dy(G)  is  the  set  of  all  input-output  pairs  of  f that  can  be  computed  'immediately'*  from  the 
input-output  pairs  in  & For  example  we  have  the  following  results  for  our  implementation  of  the 
fibonacci  function 

0«b<«>  ■ 1>  <*  1>1 

Dfib({<l  1>  <2  1>})  a (<1  1>  <2  1>  <3  2>) 

Dfjb((<l  1>  <2  1>  <0  4>})  a {<1  l>  <2  1>  <3  2>} 

0fib({<3  2>  <4  3>»  a {<1  1>  <2  1>  <S  5>) 

Lemma:  If  f behaves  like  a mathematical  function,  then  Of  is  a continuous  functional 

Proof:  From  its  definition  Dy  is  clearly  monotonic  We  will  use  N to  denote  the  natural  numbers  [i.e.  the 
non-negative  integers!  Suppose  that  (Xj|  KN)  is  a chain  of  sets  of  ordered  pairs  so  that  X|  £ X|4,j.  To 
prove  that  Dy  is  continuous  we  shall  prove  that 

U,<NW  • DflUjyyy  X|) 

Clearly 

UifN  W C *l> 

by  the  monotonicity  of  Dy.  To  prove  the  set  inclusion  the  other  way  around  suppose 

<x,y>  « DylUitN  X|) 

It  follows  from  the  definition  of  Dy  that  <x,yXf  and 

immediate  ■ descewdsntsy(<«,y»  £ X| 

Therefore  there  exists  a natural  number  n such  that  immadtots' descends  ' £ Xn  since  the 

immediate  f -descendants  of  <x,y>  are  finite.  Thus  <x,yXOy(Xn)  and 
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<*,y>  < Uhn  W 

Definition:  A sequence  <Xj  yf>  such  that  each  <xj  yjXf  will  be  said  to  be  a descending  f-chain  if  each 
y|+i>  is  an  immediate  (-descendant  of  <xj  y(>. 

Example:  The  following  are  descending  fib-chains 

[<6  »>  <4  3>  <3  2>  <1  1>] 

[<7  13>  <5  5>  <3  2>  <2  1>] 

Lemma:  If  <x  yXf  then  there  are  only  finitely  many  descending  f-chains  begining  with  oc  y>. 

Proof:  Follows  from  the  fact  that  there  are  only  finitely  many  events  between  two  events  of  the  form 
[<  <-**  x,  reply-to:  efl  and  |e  <~~  [ rtply  yfl  in  the  continuation  ordering. 

Definition:  If  <x  yx»  then  heigM(f,<x  y>)  will  be  defined  as  the  maximum  length  of  the  descending 
f-chains  beginning  with  <x  y>. 

Lemma:  If  <x  yXf  then  <x  yx y>^({})  where  Dfn  is  the  n-fokl  composition  of  D(  with  itself. 

Thooromt  If  an  actor  f behaves  like  a mathematical  function  then  D(  is  a continuous  functional  in  the 
sense  of  Scott  and  f is  the  limit  of  Df  i.e. 


graph(f)  • U|<N  0|f({}) 

where  graphff)  is  the  set  of  input-output  pairs  of  f.  It  immediately  follows  that  graph(f)  is  the  minimal 
fixed  point  of  Of  since 


graph(f)  ■ Df(grapMf)) 

Conversely,  if  f is  the  limit  of  a continuous  functional  then  the  method  used  above  can  be  used  to 
construct  a history  for  each  request  to  f such  that  the  histories  are  consistent  and  each  history  has  the 
property  that  each  event  has  only  finitely  many  immediate  successors  and  finitely  many  predecessors  in 
the  continuation  ordering. 

The  above  theorem  makes  precise  the  physical  basis  for  believing  that  the  graph  of  every  physically 
realizable  mathematical  function  is  the  limit  of  a continuous  functional:  the  Law  of  Finitely  Many 
Immediate  Successors  and  the  Law  of  Finite  Chains  between  two  Events  in  the  Continuation  Ordering. 
As  currently  developed  the  Scott-Strachey  theory  does  not  account  for  the  the  properties  of  the  arrival 
orderings  of  actors  such  as  synchronization  primitives  and  shared  data  bases.  An  interesting  topic  that 
is  left  open  for  future  research  is  how  the  Scott-Strachey  theory  can  be  extended  in  a natural  way  to 
encompass  the  physical  constraints  imposed  by  the  arrival  orderings  of  actors. 


22 


Hewitf  and  Bator 


ACTORS 


j 


SECTION  Xi  — FUTURE  WORK 

When  we  first  began  our  Investigation  into  message-passing  system  we  developed  the  intuitively 
appealing  idea  of  "actors"  as  agents  which  communicate  by  passing  messages  This  intuitive  notion 
proved  to  be  too  naive  a basis  for  precise  technical  work  in  the  same  way  that  the  intuitive  notion  of  a 
"set"  as  a collection  of  objects  proved  to  be  too  naive  a basis  in  mathematics,  ""he  solution  has  been  the 
development  of  the  axioms  in  this  paper  which  are  intended  to  serve  as  the  first  step  in  developing 
axioms  which  capture  the  intuitive  notion  of  actors  as  agents  which  communicate  by  sending  and 
receiving  messages. 

There  remains  a great  deal  of  work  to  be  done  in  the  development  of  the  theory  presented  in  this 
paper.  The  "completeness"  of  the  axioms  presented  here  needs  to  be  intensively  studied  to  determine  if 
they  can  be  significantly  strengthened. 

A mathematical  characterization  of  the  models  which  satisfy  the  axioms  needs  to  oe  developed.  The 
characterization  should  include  a description  of  a standard  model  obtained  by  a constructive  method  for 
enumerating  all  the  computation  histories  of  a system  that  satisfy  the  axioms  in  this  paper.  The 
development  ot  such  a constructive  model  will  prove  the  consistency  of  the  axioms  in  this  paper  as  well 
as  providing  ; standard  model  In  which  the  axioms  can  be  interpreted. 

We  would  like  to  apply  the  semantic  theory  developed  in  this  paper  in  several  directions.  The 
semantics  of  programming  languages  for  multi-processing  problem  solving  language  such  as  KRL, 
OWL,  PLASMA,  SIMULA,  SMALLTALK,  AMORD,  and  the  quantificanonal  calculus  need  to  be 
rigorously  developed.  In  this  way  we  hope  to  be  able  to  make  precise  technical  contributions  to  the 
declarative-procedural"  controversy. 

There  are  a number  of  questions  concerned  with  how  efficiently  actor  systems  can  oe  implemented  on 
networks  oi  machines.  In  terms  of  the  physical  transport  of  information  there  are  several  ways  in 
which  an  event  can  be  implemented.  The  information  in  the  messenger  can  be  physically  transported  to 
the  target,  rhe  target  can  be  transporteo  to  the  messenger,  or  the  two  can  rendezvous  at  some  other 
location.  Under  differing  circumstances  any  one  of  the  above  possibilities  might  be  more  efficient.  For 

example  if  the  target  is  a small  function  which  makes  use  of  a large  number  of  the  extended 

acquaintances  of  the  messenger  then  it  is  probably  more  efficient  to  transport  tnc  target  tc  the 
messenger.  On  the  other  hand  If  the  target  is  a large  data  base  which  is  searched  according  to  the 

directions  of  a small  query  in  the  messenger,  then  it  is  probably  more  efficient  to  transport  the 

messenger  to  the  target  Research  is  needed  to  develop  dynamic  mechanisms  fot  deciding  what 
information  to  transport  for  computation:  that  are  physically  distributed  on  a nutwon  of  machines. 
Hopefully  some  general  mechanisms  can  be  developed  which,  in  practice,  yield  acceptable  ef  ficiency. 
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SECTION  XU  — CONCLUSION 


In  this  paper  we  have  presented  some  laws  that  must  be  obeyed  by  the  computations  of  communicating 
parallel  processes.  The  theory  is  based  on  axlomatizlng  the  causal  and  incidental  relations  between 
computational  events  where  each  event  consists  of  sending  a message.  An  important  advantage  of  the 
actor  message-passing  model  is  that  specifications  for  actors  can  be  expressed  directly  in  terms  of  the 
events  involving  those  actors.  Our  approach  is  different  from  the  more  usual  one  which  is  to  postulate 
the  existence  and  "fairness"  of  some  underlying  global  "scheduler"  [21]  or  "oracle"  [221  Partial  orders 
provide  a means  for  concentrating  on  the  causal  relations  among  event  as  opposed  to  time  relationships 
that  result  from  some  arbitrary  interleaving. 


The  development  of  histories  in  the  actor  model  of  computation  as  partial  orders  of  events  as  a 
generalization  of  the  previous  development  as  sequences  of  events  has  proven  to  be  very  fruitful.  The 
partial  orders  -aci->,  -en->x  for  each  actor  x,  and  are  all  physically  well  grounded  In  the 

sense  that  if  two  events  are  observed  to  be  related  in  a certain  way  in  some  observation  frame  then  they 
will  be  observed  to  be  related  in  the  same  way  in  all  observation  frames.  Each  of  these  different 
orderings  serves  its  own  purpose  in  the  model.  The  following  table  summarizes  the  partial  orders 
which  we  have  introduced  to  describe  the  histories  of  computations: 


-eel-> 


— > 


-> 


activation 

arrival 

a-» a 

cvHiwnfo 

continuation 


causality  batwaen  events 
local  timo  of  arrival  of  messages  sent  to  x 
general  notion  of  ono  event  preceding  another 
nested  activities 


Partial  orders  of  histories  have  been  used  to  develop  specification  and  proof  techniques  for  modular 
synchronization  primitives  0W21  The  machinery  of  partial  orders  of  events  provides  the  semantic  glue 
needed  to  relate  the  specifications  and  implementations  of  communicating  parallel  processes. 

This  paper  has  traced  some  of  the  important  relationships  between  the  actor  message-passing  model  of 
computation  and  classical  denotations!,  semantics.  It  has  been  proved  that  every  actor  which  behaves 
like  a mathematical  function  is  the  limit  of  a continuous  functional.  This  result  provides  a physical 
basis  for  the  treatment  of  continuity  in  the  Scott-Strachey  theory  of  computation.  The  actor 
message-passing  model  has  important  applications  for  the  semantics  of  communicating  parallel  processes 
which  will  be  explored  in  subsequent  papers. 
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